草庐IT

java - 在 nestedscrollview 中检查 recyclerview 滚动状态

全部标签

ruby-on-rails - 有没有办法在 Ruby on Rails 的控制台中检查命令的性能?

我找不到任何关于这是否可能的信息,但它会很有用及时思考。例如,我试图找出其中哪一个更快:[val2,val3,val4,val5,val6].find{|x|x!=val1}[val2,val3,val4,val5,val6].all?{|x|x==val1}有这样的东西吗?[val2,val3,val4,val5,val6].find{|x|x!=val1}.performance 最佳答案 有!而且您甚至不需要Rails。查看benchmark来自标准库。作为示例:require'benchmark'putsBenchmark.

出现错误时的 Ruby/Thor 退出状态

我是Thor(和Ruby)的新手,我正在考虑在构建脚本中使用它,因为据说它可以替代Rake(从而替代Make)。然而,经过短暂的试用,我对它返回的错误状态感到困惑。我快速浏览了wiki,但没有看到任何提及。只有第一个“简单示例”,test.thor:classTest版本号:eruve>thorversionThor0.18.1我尝试了以下,故意错误的命令:eruve>ruby--version;thortest:examplebadarg;echoexitstatus:$?ruby2.0.0p195(2013-05-14revision40734)[x86_64-darwin10.8

ruby-on-rails - 为什么 `rake db:drop` 失败时退出状态为 0,并且不引发错误?

我惊讶地发现,当rakedb:drop(假设是Rails的其他内置raketasks)失败时,bash状态代码为0。$rakedb:dropcouldnotconnecttoserver:ConnectionrefusedIstheserverrunningonhost"localhost"(::1)andacceptingTCP/IPconnectionsonport5432?...$echo$?0也许更令人惊讶的是,当从Rails中调用任务时,它甚至不会引发错误。2.3.0:001>begin2.3.0:002>Rake::Task["db:drop"].invoke2.3.0:0

ruby - 在 JRuby 中,如何确定导致 java.lang.ThreadDeath 的原因?

在为一些与JRuby中的临时文件交互的代码运行单元测试时,我有时会得到以下信息:Exception:java.lang.ThreadDeaththrownfromtheUncaughtExceptionHandlerinthread"Thread-6395"它似乎没有引起任何问题,但这是怎么回事,我如何确定它发生在哪里?我尝试打开-d,但这并没有给我异常的堆栈跟踪。 最佳答案 FWIW:这可能与http://jira.codehaus.org/browse/JRUBY-7074有关.我偶尔会在不使用反引号但调用系统的JRuby程序中

ruby - 如何获取使用 IO.popen 调用的命令的退出状态?

我正在使用IO.popen执行命令并像这样捕获输出:process=IO.popen("sudo-uservice_user-istart_service.sh")do|io|whileline=io.getsline.chomp!process_log_line(line)endend如何捕获*start_service.sh*的退出状态? 最佳答案 您可以通过引用$?捕获通过IO.open()调用的命令的退出状态,只要您关闭了block末尾的管道即可。在上面的例子中,你会这样做:process=IO.popen("sudo-us

ruby - ruby 中的线程安全外部进程,以及检查退出状态

我想在Ruby中运行一段调用外部程序的线程安全脚本,然后检查该外部程序的退出状态。最好的方法是什么?到目前为止,我一直在检查$?,但我认为我遇到了与程序其他部分的竞争条件。下面是一些示例代码:Thread.newdo`external_program`if$?.exitstatus==0#itworked.else#itdidn'twork.endend理想情况下,我会做类似的事情Process.new(`external_program`).exitstatus因此exitstatus与that进程密不可分,而不是恰好完成的最后一个进程。有什么办法吗? 最

ruby - 在 Ruby 中从 MongoDB 中检索字段的子集

我试图通过在Ruby中进行的查询从MongoDB获取字段的子集,但它似乎不起作用。它不返回任何结果这是ruby代码:coll.find("title"=>'Halo',:fields=>["title","isrc"])#thisdoesn'twork如果我删除字段散列,它会工作,返回包含所有字段的结果coll.find("title"=>'Halo')#thisworks查看mongodb控制台,第一个查询在mongodb服务器上结束,如下所示:{title:"Halo",fields:["title","isrc"]}如果我尝试从mongo客户端控制台进行查询,它会工作,我会得到结

ruby-on-rails - Rails 4 AbstractController::Metal 渲染状态 != 200(即 401、404)

我正在我的应用程序中实现一个简单的API来与Android应用程序通信。我主要尝试使用AbstractController::Metal来提高性能。我遇到的问题是渲染忽略了我传递的状态选项。非常简单的例子:classApi::V1::ApiController打电话curl-v-XGEThttp://app.dev:3000/api/v1/sessions.json我希望收到401,但我却收到200OK:>GET/api/v1/sessions.jsonHTTP/1.1>User-Agent:curl/7.30.0>Host:app.dev:3000>Accept:*/*>有什么想法吗

ruby - 在 Sinatra 的自定义错误 block 中设置状态代码

我有一个400状态代码的自定义错误消息:get'/do'doraiseParamXMissingErrorunlessparams['x']enderrorParamXMissingErrordohaml:custom_error_pageend我希望ParamXMissingError为400,但是当我运行上面的代码并通过FirefoxNetwork工具检查时,Sinatra似乎实际上返回了500,而不是400。如何让它显示custom_error_page.haml并返回400?最好是从错误block内部处理状态代码和页面,而不是我在引发ParamXMissingError时四处乱

ruby - 在 RSpec 中检查(不存在) `puts`

我在一个ruby​​项目中使用rspec进行测试,我想说明在使用-q选项时我的程序不应输出任何内容。我试过:Kernel.should_not_receive:puts当有输出到控制台时,这并没有导致测试失败。如何验证文本输出的缺失? 最佳答案 puts在内部使用$stdout。由于它的工作方式,最简单的检查方法是简单地使用:$stdout.should_not_receive(:write)检查没有按预期写入标准输出。Kernel.puts(如上所述)只会导致测试失败被明确地这样称呼(例如Kernel.puts“Sometext”